package cn.iocoder.yudao.module.esim.dal.mysql.esproduct;

import java.util.*;

import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
import cn.iocoder.yudao.module.esim.dal.dataobject.esproduct.EsProductDO;
import org.apache.ibatis.annotations.Mapper;
import cn.iocoder.yudao.module.esim.controller.admin.esproduct.vo.*;

/**
 * eSim商品 Mapper
 *
 * @author 超管
 */
@Mapper
public interface EsProductMapper extends BaseMapperX<EsProductDO> {

    default PageResult<EsProductDO> selectPage(EsProductPageReqVO reqVO) {
        return selectPage(reqVO, new LambdaQueryWrapperX<EsProductDO>()
                .eqIfPresent(EsProductDO::getId, reqVO.getId())
                .likeIfPresent(EsProductDO::getName, reqVO.getName())
                .eqIfPresent(EsProductDO::getDataAllowanceMb, reqVO.getDataAllowanceMb())
                .eqIfPresent(EsProductDO::getValidityPeriodDays, reqVO.getValidityPeriodDays())
                .likeIfPresent(EsProductDO::getCountry, reqVO.getCountry())
                .eqIfPresent(EsProductDO::getType, reqVO.getType())
                .orderByDesc(EsProductDO::getId));
    }

}